package com.study.controller;


import com.study.pojo.Dept;
import com.study.pojo.Result;
import com.study.service.DeptService;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

/**
 * 类名称：DeptController
 * 描述：部门控制器
 *
 * @author: admin
 * 创建时间: 2025/03/03
 */
@Slf4j
@RequestMapping("/depts")
@RestController
public class DeptController {
    @Autowired
    private DeptService deptService;

    /**
     * 查找部门表
     *
     * @return {@link Result }
     * @author Lixx
     * @date 2025/03/03
     */
    @GetMapping
    public Result findAll(){
        log.info("查找部门表");
        List<Dept> deptList = deptService.findAll();
        return Result.success(deptList);
    }

    /**
     * 删除部门
     *
     * @param id 编号
     * @return {@link Result }
     * @author Lixx
     * @date 2025/03/04
     */
    @DeleteMapping
    public Result deleteDept(Integer id){
        log.info("删除的id：{}", id);
        deptService.deleteDept(id);
        return Result.success();
    }

    /**
     * 添加部门
     *
     * @param dept 部门
     * @return {@link Result }
     * @author Lixx
     * @date 2025/03/04
     */
    @PostMapping
    public Result addDept(@RequestBody Dept dept){
        log.info("添加的部门：{}", dept);
        deptService.addDept(dept);
        return Result.success();
    }

    /**
     * 按 ID 查找
     *
     * @param id 编号
     * @return {@link Result }
     * @author Lixx
     * @date 2025/03/05
     */
    @GetMapping("/{id}")
    public Result getById(@PathVariable Integer id){
        log.info("根据ID查询, id:{}", id);
        Dept dept = deptService.findById(id);
        return Result.success(dept);
    }


    /**
     * 更新部门
     *
     * @param dept 部门对象
     * @return {@link Result }
     * @author Lixx
     * @date 2025/03/05
     */

    @PutMapping
    public Result updateDept(@RequestBody Dept dept){
        log.info("修改的部门：{}", dept);
        deptService.updateDept(dept);
        return Result.success();
    }
}
